一步步排查解决java.lang.NoSuchFieldError 和 NoSuchMethodError问题

您所在的位置:网站首页 setup timeout 一步步排查解决java.lang.NoSuchFieldError 和 NoSuchMethodError问题

一步步排查解决java.lang.NoSuchFieldError 和 NoSuchMethodError问题

2024-01-03 00:05| 来源: 网络整理| 查看: 265

今天遇到了一个问题(如题),我在思考要不要记录下,最终决定写一个简单的小记录。我感觉大牛必备的两个技能:1、设计别人想不到的架构 2、解决别人无可奈何的问题。 遇到下面这个问题会有四种人。(第四种人看完整篇文章)1、如果你之前没有遇到过,你会越查越崩溃;2、如果你之前遇到过,解决了,可能在比较明显的情况下会能快速定位,但是在很多情况下,查了好久之后你会怀疑自己说的到底对不对。3、第三种人遇到过这个问题,查了半天查不到,然后就一顿胡乱操作最后莫名其妙的好了、或者别人给解决、在差劲一点的就换个恶心的代码写法就完事啦,恭喜你永远的程序员。 1、报错信息 java.lang.NoSuchFieldError 和 NoSuchMethodError 2、场景 通过Maven引入了一个jar包,某一天新增了一个类的属性或者静态属性。然后发现编译完全正确,但是实际运行一直在报NoSuchFieldError。 3、造成原因只有以下两种(不用想其他的,没有其他可能)

1、你项目中有同一个jar包的不同版本,编译和运行时使用了不同的jar包。比如有两个版本1.1.3和1.1.4(有新增属性)。编译的时候使用1.1.4,编译正常通过。但是运行的时候使用的是1.1.3。 2、你的项目中存在和jar包中路径和类名完全相同的类。因为你新增了属性本地类中没有,所以编译的时候会自动使用Jar包中的对象,但是运行的时候则会优先使用本地的对象!!!

4、排查流程 1、第一步:排查存在多个Jar包引用 使用ideal自带到Maven工具(show Dependencies),如果查处两个的话就要注意啦(敲黑板),你可以直接点到不是你需要的那个版本,进入查看下是从哪个地方依赖的。在这里插入图片描述如果是你项目引入的,直接删掉就解决啦,如果是传递依赖(你引用的jar引用了这个jar包),需要使用标签去排除掉。 io.vertx vertx-core ${vertx.version} netty-codec io.netty 顺手推荐一个工具:Maven Helper 2、第二步:排查你们项目中有相同路径和命名的类

在这里插入图片描述

敲黑板:一定要勾选上include non-project items 才能查询到jar包中的类。如果本地有一样的话,看你的抉择啦,删除哪一个你自己选。

上面两步绝对解决问题,如果你试过还是没找到原因,那你找下你的同事check一下,不会有其他可能。



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3